<?php

declare(strict_types=1);

namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\TextData;

use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
use PHPUnit\Framework\Attributes\DataProvider;

class SearchTest extends AllSetupTeardown
{
    #[DataProvider('providerSEARCH')]
    public function testSEARCH(mixed $expectedResult, mixed $findText = 'omitted', mixed $withinText = 'omitted', mixed $start = 'omitted'): void
    {
        $this->mightHaveException($expectedResult);
        $sheet = $this->getSheet();
        if ($findText === 'omitted') {
            $sheet->getCell('B1')->setValue('=SEARCH()');
        } elseif ($withinText === 'omitted') {
            $this->setCell('A1', $findText);
            $sheet->getCell('B1')->setValue('=SEARCH(A1)');
        } elseif ($start === 'omitted') {
            $this->setCell('A1', $findText);
            $this->setCell('A2', $withinText);
            $sheet->getCell('B1')->setValue('=SEARCH(A1, A2)');
        } else {
            $this->setCell('A1', $findText);
            $this->setCell('A2', $withinText);
            $this->setCell('A3', $start);
            $sheet->getCell('B1')->setValue('=SEARCH(A1, A2, A3)');
        }
        $result = $sheet->getCell('B1')->getCalculatedValue();
        self::assertEquals($expectedResult, $result);
    }

    public static function providerSEARCH(): array
    {
        return require 'tests/data/Calculation/TextData/SEARCH.php';
    }

    /** @param mixed[] $expectedResult */
    #[DataProvider('providerSearchArray')]
    public function testSearchArray(array $expectedResult, string $argument1, string $argument2): void
    {
        $calculation = Calculation::getInstance();

        $formula = "=SEARCH({$argument1}, {$argument2})";
        $result = $calculation->calculateFormula($formula);
        self::assertSame($expectedResult, $result);
    }

    public static function providerSearchArray(): array
    {
        return [
            'row vector #1' => [[[3, 4, '#VALUE!']], '"L"', '{"Hello", "World", "PhpSpreadsheet"}'],
            'column vector #1' => [[[3], [4], ['#VALUE!']], '"L"', '{"Hello"; "World"; "PhpSpreadsheet"}'],
            'matrix #1' => [[[3, 4], ['#VALUE!', 5]], '"L"', '{"Hello", "World"; "PhpSpreadsheet", "Excel"}'],
        ];
    }
}
